minus2(0, y) -> 0
minus2(s1(x), 0) -> s1(x)
minus2(s1(x), s1(y)) -> minus2(x, y)
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
if3(true, x, y) -> x
if3(false, x, y) -> y
perfectp1(0) -> false
perfectp1(s1(x)) -> f4(x, s1(0), s1(x), s1(x))
f4(0, y, 0, u) -> true
f4(0, y, s1(z), u) -> false
f4(s1(x), 0, z, u) -> f4(x, u, minus2(z, s1(x)), u)
f4(s1(x), s1(y), z, u) -> if3(le2(x, y), f4(s1(x), minus2(y, x), z, u), f4(x, u, z, u))
↳ QTRS
↳ DependencyPairsProof
minus2(0, y) -> 0
minus2(s1(x), 0) -> s1(x)
minus2(s1(x), s1(y)) -> minus2(x, y)
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
if3(true, x, y) -> x
if3(false, x, y) -> y
perfectp1(0) -> false
perfectp1(s1(x)) -> f4(x, s1(0), s1(x), s1(x))
f4(0, y, 0, u) -> true
f4(0, y, s1(z), u) -> false
f4(s1(x), 0, z, u) -> f4(x, u, minus2(z, s1(x)), u)
f4(s1(x), s1(y), z, u) -> if3(le2(x, y), f4(s1(x), minus2(y, x), z, u), f4(x, u, z, u))
F4(s1(x), 0, z, u) -> MINUS2(z, s1(x))
F4(s1(x), s1(y), z, u) -> F4(s1(x), minus2(y, x), z, u)
F4(s1(x), s1(y), z, u) -> MINUS2(y, x)
F4(s1(x), s1(y), z, u) -> F4(x, u, z, u)
F4(s1(x), s1(y), z, u) -> LE2(x, y)
F4(s1(x), s1(y), z, u) -> IF3(le2(x, y), f4(s1(x), minus2(y, x), z, u), f4(x, u, z, u))
LE2(s1(x), s1(y)) -> LE2(x, y)
PERFECTP1(s1(x)) -> F4(x, s1(0), s1(x), s1(x))
MINUS2(s1(x), s1(y)) -> MINUS2(x, y)
F4(s1(x), 0, z, u) -> F4(x, u, minus2(z, s1(x)), u)
minus2(0, y) -> 0
minus2(s1(x), 0) -> s1(x)
minus2(s1(x), s1(y)) -> minus2(x, y)
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
if3(true, x, y) -> x
if3(false, x, y) -> y
perfectp1(0) -> false
perfectp1(s1(x)) -> f4(x, s1(0), s1(x), s1(x))
f4(0, y, 0, u) -> true
f4(0, y, s1(z), u) -> false
f4(s1(x), 0, z, u) -> f4(x, u, minus2(z, s1(x)), u)
f4(s1(x), s1(y), z, u) -> if3(le2(x, y), f4(s1(x), minus2(y, x), z, u), f4(x, u, z, u))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
F4(s1(x), 0, z, u) -> MINUS2(z, s1(x))
F4(s1(x), s1(y), z, u) -> F4(s1(x), minus2(y, x), z, u)
F4(s1(x), s1(y), z, u) -> MINUS2(y, x)
F4(s1(x), s1(y), z, u) -> F4(x, u, z, u)
F4(s1(x), s1(y), z, u) -> LE2(x, y)
F4(s1(x), s1(y), z, u) -> IF3(le2(x, y), f4(s1(x), minus2(y, x), z, u), f4(x, u, z, u))
LE2(s1(x), s1(y)) -> LE2(x, y)
PERFECTP1(s1(x)) -> F4(x, s1(0), s1(x), s1(x))
MINUS2(s1(x), s1(y)) -> MINUS2(x, y)
F4(s1(x), 0, z, u) -> F4(x, u, minus2(z, s1(x)), u)
minus2(0, y) -> 0
minus2(s1(x), 0) -> s1(x)
minus2(s1(x), s1(y)) -> minus2(x, y)
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
if3(true, x, y) -> x
if3(false, x, y) -> y
perfectp1(0) -> false
perfectp1(s1(x)) -> f4(x, s1(0), s1(x), s1(x))
f4(0, y, 0, u) -> true
f4(0, y, s1(z), u) -> false
f4(s1(x), 0, z, u) -> f4(x, u, minus2(z, s1(x)), u)
f4(s1(x), s1(y), z, u) -> if3(le2(x, y), f4(s1(x), minus2(y, x), z, u), f4(x, u, z, u))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ QDP
LE2(s1(x), s1(y)) -> LE2(x, y)
minus2(0, y) -> 0
minus2(s1(x), 0) -> s1(x)
minus2(s1(x), s1(y)) -> minus2(x, y)
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
if3(true, x, y) -> x
if3(false, x, y) -> y
perfectp1(0) -> false
perfectp1(s1(x)) -> f4(x, s1(0), s1(x), s1(x))
f4(0, y, 0, u) -> true
f4(0, y, s1(z), u) -> false
f4(s1(x), 0, z, u) -> f4(x, u, minus2(z, s1(x)), u)
f4(s1(x), s1(y), z, u) -> if3(le2(x, y), f4(s1(x), minus2(y, x), z, u), f4(x, u, z, u))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
LE2(s1(x), s1(y)) -> LE2(x, y)
POL( LE2(x1, x2) ) = max{0, 2x1 + 2x2 - 1}
POL( s1(x1) ) = 2x1 + 2
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
↳ QDP
minus2(0, y) -> 0
minus2(s1(x), 0) -> s1(x)
minus2(s1(x), s1(y)) -> minus2(x, y)
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
if3(true, x, y) -> x
if3(false, x, y) -> y
perfectp1(0) -> false
perfectp1(s1(x)) -> f4(x, s1(0), s1(x), s1(x))
f4(0, y, 0, u) -> true
f4(0, y, s1(z), u) -> false
f4(s1(x), 0, z, u) -> f4(x, u, minus2(z, s1(x)), u)
f4(s1(x), s1(y), z, u) -> if3(le2(x, y), f4(s1(x), minus2(y, x), z, u), f4(x, u, z, u))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
MINUS2(s1(x), s1(y)) -> MINUS2(x, y)
minus2(0, y) -> 0
minus2(s1(x), 0) -> s1(x)
minus2(s1(x), s1(y)) -> minus2(x, y)
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
if3(true, x, y) -> x
if3(false, x, y) -> y
perfectp1(0) -> false
perfectp1(s1(x)) -> f4(x, s1(0), s1(x), s1(x))
f4(0, y, 0, u) -> true
f4(0, y, s1(z), u) -> false
f4(s1(x), 0, z, u) -> f4(x, u, minus2(z, s1(x)), u)
f4(s1(x), s1(y), z, u) -> if3(le2(x, y), f4(s1(x), minus2(y, x), z, u), f4(x, u, z, u))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
MINUS2(s1(x), s1(y)) -> MINUS2(x, y)
POL( MINUS2(x1, x2) ) = max{0, 2x1 + 2x2 - 1}
POL( s1(x1) ) = 2x1 + 2
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
minus2(0, y) -> 0
minus2(s1(x), 0) -> s1(x)
minus2(s1(x), s1(y)) -> minus2(x, y)
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
if3(true, x, y) -> x
if3(false, x, y) -> y
perfectp1(0) -> false
perfectp1(s1(x)) -> f4(x, s1(0), s1(x), s1(x))
f4(0, y, 0, u) -> true
f4(0, y, s1(z), u) -> false
f4(s1(x), 0, z, u) -> f4(x, u, minus2(z, s1(x)), u)
f4(s1(x), s1(y), z, u) -> if3(le2(x, y), f4(s1(x), minus2(y, x), z, u), f4(x, u, z, u))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDPOrderProof
F4(s1(x), s1(y), z, u) -> F4(s1(x), minus2(y, x), z, u)
F4(s1(x), s1(y), z, u) -> F4(x, u, z, u)
F4(s1(x), 0, z, u) -> F4(x, u, minus2(z, s1(x)), u)
minus2(0, y) -> 0
minus2(s1(x), 0) -> s1(x)
minus2(s1(x), s1(y)) -> minus2(x, y)
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
if3(true, x, y) -> x
if3(false, x, y) -> y
perfectp1(0) -> false
perfectp1(s1(x)) -> f4(x, s1(0), s1(x), s1(x))
f4(0, y, 0, u) -> true
f4(0, y, s1(z), u) -> false
f4(s1(x), 0, z, u) -> f4(x, u, minus2(z, s1(x)), u)
f4(s1(x), s1(y), z, u) -> if3(le2(x, y), f4(s1(x), minus2(y, x), z, u), f4(x, u, z, u))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
F4(s1(x), s1(y), z, u) -> F4(x, u, z, u)
F4(s1(x), 0, z, u) -> F4(x, u, minus2(z, s1(x)), u)
Used ordering: Polynomial Order [17,21] with Interpretation:
F4(s1(x), s1(y), z, u) -> F4(s1(x), minus2(y, x), z, u)
POL( F4(x1, ..., x4) ) = max{0, 2x1 + 2x3 + x4 - 2}
POL( minus2(x1, x2) ) = x1
POL( 0 ) = 1
POL( s1(x1) ) = x1 + 2
minus2(s1(x), s1(y)) -> minus2(x, y)
minus2(0, y) -> 0
minus2(s1(x), 0) -> s1(x)
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ QDPOrderProof
F4(s1(x), s1(y), z, u) -> F4(s1(x), minus2(y, x), z, u)
minus2(0, y) -> 0
minus2(s1(x), 0) -> s1(x)
minus2(s1(x), s1(y)) -> minus2(x, y)
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
if3(true, x, y) -> x
if3(false, x, y) -> y
perfectp1(0) -> false
perfectp1(s1(x)) -> f4(x, s1(0), s1(x), s1(x))
f4(0, y, 0, u) -> true
f4(0, y, s1(z), u) -> false
f4(s1(x), 0, z, u) -> f4(x, u, minus2(z, s1(x)), u)
f4(s1(x), s1(y), z, u) -> if3(le2(x, y), f4(s1(x), minus2(y, x), z, u), f4(x, u, z, u))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
F4(s1(x), s1(y), z, u) -> F4(s1(x), minus2(y, x), z, u)
POL( F4(x1, ..., x4) ) = 2x1 + x2 + x3
POL( minus2(x1, x2) ) = x1
POL( 0 ) = 2
POL( s1(x1) ) = 2x1 + 2
minus2(s1(x), s1(y)) -> minus2(x, y)
minus2(0, y) -> 0
minus2(s1(x), 0) -> s1(x)
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
minus2(0, y) -> 0
minus2(s1(x), 0) -> s1(x)
minus2(s1(x), s1(y)) -> minus2(x, y)
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
if3(true, x, y) -> x
if3(false, x, y) -> y
perfectp1(0) -> false
perfectp1(s1(x)) -> f4(x, s1(0), s1(x), s1(x))
f4(0, y, 0, u) -> true
f4(0, y, s1(z), u) -> false
f4(s1(x), 0, z, u) -> f4(x, u, minus2(z, s1(x)), u)
f4(s1(x), s1(y), z, u) -> if3(le2(x, y), f4(s1(x), minus2(y, x), z, u), f4(x, u, z, u))